<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>基本使用</title>
    <!-- 引入 vue -->
    <script type="text/javascript" src="../node_modules/vue/dist/vue.js"></script>
</head>
<body>
    <!--
		Vue中使用组件的三大步骤：
			一、定义组件(创建组件)
			二、注册组件
			三、使用组件(写组件标签)

		一、如何定义一个组件？
			使用 Vue.extend(options) 创建，其中 options 和 new Vue(options) 时传入的那个 options 几乎一样，但也有点区别；
			区别如下：
				1.el不要写，为什么？ ——— 最终所有的组件都要经过一个vm的管理，由vm中的el决定服务哪个容器。
				2.data必须写成函数，为什么？ ———— 避免组件被复用时，数据存在引用关系。
			备注：使用template可以配置组件结构。

		二、如何注册组件？
			1.局部注册：靠 new Vue 的时候传入 components 选项
			2.全局注册：靠 Vue.component('组件名',组件)

		三、编写组件标签：
			<school></school>
	-->
    <div id="root">
        <!-- 第三步：编写组件标签 -->
        <xuexiao></xuexiao>
        <hr>
        <xuesheng></xuesheng>
        <hr>
        <hello></hello>
        <hr>
    </div>
    <div id="root2">
        <hello></hello>
    </div>
</body>
<script type="text/javascript">
    // 第一步：创建 school 组件
    const school = Vue.extend({
        template: `
            <div>
                <h2>学校名称：{{schoolName}}</h2>
                <h2>学校地址：{{address}}</h2>
                <button @click="showName">点我显示学校名称</button>
            </div>
        `,
        // 组件定义时，一定不要写 el 配置项，因为最终所有的组件都要被一个 vue 实例管理，由 vue 实例决定服务于哪个容器
        // el: '#root',
        data() {
            return {
                schoolName: '尚硅谷',
                address: '北京昌平',
            };
        },
        methods: {
            showName(){
                alert(this.schoolName);
            }
        }
    });

    // 第一步：创建 hello 组件
    const hello = Vue.extend({
        template:  `
            <div>
                <h2>你好啊！{{name}}</h2>
            </div>
        `,
        data() {
            return {
                name: 'Tom'
            }
        }
    });

    // 第一步：创建 student 组件
    const student = Vue.extend({
        template:`
			<div>
				<h2>学生姓名：{{studentName}}</h2>
				<h2>学生年龄：{{age}}</h2>
			</div>
        `,
        data() {
            return {
                studentName: '张三',
                age: 18
            }
        }
    });

    Vue.component('hello', hello);

    // 创建 vm
    new Vue({
        el: '#root',
        // 第二步：注册组件（局部注册）
        components: {
            xuexiao: school,
            xuesheng: student
        }
    });

    new Vue({
        el: '#root2'
    })
</script>
</html>